<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <script src="../js/drag.js"></script>
    <style>
        * {
            padding: 0;
            margin: 0;
        }

        .box {
            width: 200px;
            height: 200px;
            background-color: #6ff;
            position: absolute;
        }
    </style>
</head>

<body>
    <div class="box"></div>
    <div class="box"></div>
    <div class="box"></div>
    <div class="box"></div>
    <div class="box"></div>
</body>
<script>
    var box = document.getElementsByClassName("box")[0];

    var scrollWidth = document.documentElement.scrollWidth || document.body.scrollWidth;
    var scrollHeight = document.documentElement.scrollHeight || document.body.scrollHeight;
    var maxLeft = scrollWidth - box.clientWidth;
    var maxTop = scrollHeight - box.clientHeight;

    window.onresize = function () {
        var scrollWidth = document.documentElement.scrollWidth || document.body.scrollWidth;
        var scrollHeight = document.documentElement.scrollHeight || document.body.scrollHeight;
        var maxLeft = scrollWidth - box.clientWidth;
        var maxTop = scrollHeight - box.clientHeight;
    }

    var boxList = document.getElementsByClassName("box");
    for (let i = 0; i < boxList.length; i++) {
        let box = boxList[i];
        var re = new DragEle(box);
        re.init();
    }

    // var obj = {
    //     target: document.getElementsByClassName("box")[0],
    //     init() {
    //         this.dragStart();
    //         this.randColor();
    //     },
    //     dragStart: function () {
    //         var _this = this;
    //         this.target.onmousedown = function (e) {
    //             var e = e || window.event;
    //             var posX = e.offsetX;
    //             var posY = e.offsetY;
    //             _this.posX = posX;
    //             _this.posY = posY;
    //             _this.dragMove();
    //             _this.dragEnd();
    //         }
    //     },

    //     dragMove: function () {
    //         var _this = this;
    //         document.onmousemove = function (e) {
    //             var e = e || window.event;
    //             var x = e.pageX - _this.posX;
    //             var y = e.pageY - _this.posY;
    //             if (x < 0) x = 0;
    //             if (y < 0) y = 0;
    //             if (x > maxLeft) x = maxLeft;
    //             if (y > maxTop) y = maxTop;
    //             _this.target.style.left = x + "px";
    //             _this.target.style.top = y + "px";
    //         }
    //     },

    //     dragEnd: function () {
    //         document.onmouseup = function () {
    //             document.onmousemove = null;
    //         }
    //     },
    //     randColor() {
    //         var str = "0123456789abcdef";
    //         var colorStr = "#";
    //         for (var i = 0; i < 6; i++) {
    //             var index = Math.floor(Math.random() * str.length);
    //             var char = str.charAt(index);
    //             colorStr += char;
    //         }
    //         this.target.style.backgroungColor = colorStr;
    //     }
    // }
    // obj.dragStart();


    // function DragEle(ele) {
    //     this.target = ele;
    // }
    // DragEle.prototype.init = function () {
    //     this.dragStart();
    //     this.randColor();
    // }
    // DragEle.prototype.dragStart = function () {
    //     // var _this = this;
    //     this.target.onmousedown = e => {
    //         var e = e || window.event;
    //         var posX = e.offsetX;
    //         var posY = e.offsetY;
    //         this.posX = posX;
    //         this.posY = posY;
    //         this.dragMove();
    //         this.dragEnd();
    //     }
    // }
    // DragEle.prototype.dragMove = function () {
    //     var _this = this;
    //     document.onmousemove = function (e) {
    //         var e = e || window.event;
    //         var x = e.pageX - _this.posX;
    //         var y = e.pageY - _this.posY;
    //         if (x < 0) x = 0;
    //         if (y < 0) y = 0;
    //         if (x > maxLeft) x = maxLeft;
    //         if (y > maxTop) y = maxTop;
    //         _this.target.style.left = x + "px";
    //         _this.target.style.top = y + "px";
    //     }
    // }
    // DragEle.prototype.dragEnd =  () =>{
    //     document.onmouseup = function () {
    //         document.onmousemove = null;
    //     }
    // }
    // DragEle.prototype.randColor = function () {
    //     var str = "0123456789abcdef";
    //     var colorStr = "#";
    //     for (var i = 0; i < 6; i++) {
    //         var index = Math.floor(Math.random() * str.length);
    //         var char = str.charAt(index);
    //         colorStr += char;
    //     }
    //     this.target.style.backgroundColor = colorStr;
    // }

















</script>

</html>